Otimizando Access com VBA - 1
Desde as épocas dos *.dbf, utilizados junto ao consagrado Clipper, os banco de dados tiveram uma evolução significativa no mercado, mas somente vieram a se tornar popular com o surgimento do pacote Office97, onde destacava-se o Access, um banco de dados relacional desenvolvido para pequenas e médias empresas com vários recursos, incluindo controles activex, comandos em VBA (visual basic for aplication), e suporte para linguagem SQL.
Grande parte de desenvolvedores e usuários que utilizam o Access, fazem uso de macros e consultas com assistentes para criar seus projetos, o que pode apresentar resultados. Porém inadequados, o uso de macros no Access torna o banco muito mais pesado pelo fato de serem comandos predefinidos que passam a atuar como objetos, assim como as consultas, utilizadas para cálculos e relatórios, que ficam armazenadas junto ao banco, tornando objetos ativos, e por esta razão nos deparamos com conclusões erradas de que o Access é insuficiente ou menos rápido comparado aos outros bancos de dados existentes. Para tornarmos um banco de dados rápido e eficiente, devemos fazer uso correto do sistema de armazenamento, ou seja, a forma que as tabelas são criadas. Todo programador experiente sabe que o segredo está em distribuir as informações em várias tabelas que vão trabalhar de forma relacionada, este é um princípio para ter um banco de dados rápido e eficiente. Com o uso de comados SQL(Structured Query Language), podemos ter uma maior flexibilidade para manipularmos tabelas, com a vantagem de que os comandos SQL, são ativados a partir de um evento, ou seja, ao clicarmos um botão, alterarmos uma caixa de texto, ao carregar um formulário, assim sendo, os comandos SQL são apenas linhas de códigos, que não pesam no sistema, carregando consultas e tabelas, somente quando necessárias, trazendo mais agilidade e maior desempenho, e claro menor esforço para sua máquina. Para fazermos uso correto do Access, devemos utilizar seu maior potencial, que faz a diferença entre os outros bancos, ou seja o VBA, (visual basic for aplication), uma linguagem de programação muito poderosa, com 282 objetos de classe, podendo assumir 3778 métodos, ou seja 1.065.396 comandos de objetos, sem contarmos as possíbilidade de manipular as constantes e propriedades de cada objeto, por exemplo o método RunCommand, pode oferecer mais 334 manipulações, que podem influenciar mais uma série de propriedades, fora todo esse poderio, o uso de comandos vba, possibilita elaboração de códigos mais limpos e precisos, sem dúvida alguma bem melhor do que o uso das 49 macros pesadas e limitadas, que podem atingir 999 numero de ações. Com o uso de vba, podemos obter vários aspectos interessantes, podemos inserir comandos diretos em botões, imagens, caixas de textos, enfim, podemos manipular eventos em qualquer objeto estando ou não no formulário ativo, podemos desenvolver nossos botões com o Adobe Photoshop, e inserirmos em nosso formulario como imagens, aplicando os comandos ou eventos, podendo com isso elaborarmos projetos mais personalizados e profissionais . Com isso, devemos deixar claro que em meio a tantos bancos de dados existentes, (PostgreeSql, MySql, SqlServer, Oracle), cada qual tem sua importância, cada qual tem seu aspecto positivo, assim como negativo, dependendo da atividade necessária com que elaboramos nosso projeto, da mesma forma que existem diferenças entre um carro popular, um furgão e um caminhão, cada qual tem seu custo por benefício, conforme suas necessidades. Importante lembrar que não devemos deixar o fanatismo influenciar na escolha de um ou outro sistema, mas sim sabermos definir primeiramente nossa necessidade principal, e tendo a possibilidade de varias opções para banco de dados ou outros tipos de software, o que devemos é aprimorarmos nosso nível de conhecimento em cada um deles, o que é um erro comum entre muitos usuarios, que migram para outros sistemas, levados pela opinião, não pela necessidade, e muitas vezes terminam por dominar apenas 30% de cada aplicativo, anciosos por qual novidade está provir. A partir desta coluna , estarei levando uma série de códigos interessantes, limpos e praticos, que podem ser de grande utilidade para os usuários, do iMasters, assim como quero agradecer a equipe do Imasters, por manter a internet com a base com que ela foi criada, a troca de informações gratuita, e sem perder o alto nível técnico, o que vem sendo uma raridade na web. Vejamos agora alguns aspectos interesantes sobre o banco de dados Access : Banco de dados objetos de classe : 282 metodos de objetos: 3778 tamanho de arquivo(*.mdb):2 gigabytes (por capacidade de armazenamento,podendo aumentar vinculando com tabelas de outros arquivos) número de objetos: 32.768 módulos:1000 número de caracteres em uma senha:14 número de caracteres em nome de grupo:20 número de usuários simultâneos:255 tabelas caracteres em um nome de tabela:64 caracteres em um nome de campo:64 número de campos em uma tabela:255 número de tabelas abertas:2048 tamanho de uma tabela:1000 megabytes número de caracteres em campo de texto:255 número de caracteres em campo de memorando:65.535 kbytes Tamanho de um campo OLE(object linked and embed):1000 megabytes número de índices por tabela:32 número de campos por índice:10 caracteres em uma regra de validação:2.048 caracteres por registro:2000 caracteres em definição de propriedades de campo:255 consultas número de tabelas em uma consulta:32 número de campos em um conjunto de registros:255 capacidade de um conjunto de registros:1000 megabytes número de níveis em consultas aninhadas:50 número de caracteres como parametro em uma consulta parametro:255 numero de operadores AND em clausulas where ou having:40 numero de caracteres em uma instrução SQL:64.000 formulários numero de caracteres em um rótulo:2048 número de caracteres em uma caixa de texto:65.535 ferramentas internas para formulário:167 largura de um formulário:55,87cm largura de um relatorio:55,87cm altura de uma seção:55,87cm número de níveis de formulários ou relatórios aninhados:7 número de páginas por relatório:65.536
| |||||||